<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        .box {
            position: relative;
            display: block;
            width: 500px;
            height: 300px;
            border: 1px solid skyblue;
        }
        
        .text {
            position: absolute;
            display: none;
            top: 0;
            left: 0;
            width: 500px;
            height: 300px;
            border: 1px solid skyblue;
            /* display: none; */
            /* outline-style: solid; */
            /* outline: none; */
            /* resize: none; */
            outline: none;
        }
    </style>
</head>

<body>
    <!-- 创建一个`div`，它在被点击后变成`<textarea>`。
    文本区域（textarea）允许我们编辑`<div>`里的HTML。
    当用户按下`enter`键，或者`<textarea>`失去焦点时，`<textarea>`会变回`<div>`，
    并且`<textarea>`中的内容会变成`<div>`中的HTML。 -->
    <!-- <div class="box"></div> -->
    <form action="" name="form">
        <div class="box">
            <span>123</span>
        </div>
        <textarea name="text" id="" class="text"></textarea>
    </form>
    <script>
        let form = document.forms.form;
        let text = form.elements['text'];
        let box = document.querySelector('.box')
            // console.log(text);
            // text.addEventListener('click', function() {
            //     this.style.diplay = 'none';
            //     box.style.diplay = 'block'
            // })
        box.addEventListener('click', function() {
                box.style.display = 'none';
                text.style.display = 'block';
                // console.log(box.innerHTML);
                // 去除
                // let str = box.innerHTML.replace(/\s*/g, "");
                // console.log(str);
                text.value = box.innerHTML.replace(/\s*/g, "");
                text.focus();
            })
            // text.addEventListener('focus', function() {

        // })
        text.addEventListener('blur', function() {
                this.style.display = 'none';
                // console.log(text.innerText);
                box.innerHTML = text.value;
                // text.style.width
                // console.log(text.style.width);
                // console.log(text.style.height);
                box.style.display = 'block';
                box.style.width = text.style.width;
                box.style.height = text.style.height;


            })
            // text.addEventListener('keypress', function(e) {
            //         // console.log(e.keyCode);
            //         if (e.keyCode == 13) {
            //             // e.preventDefault();
            //         }
            //     })
            // document.addEventListener('keypress', function(e) {
            //     // console.log(e);
            //     if (e.keyCode == 13) {
            //         box.style.display = 'none';
            //         // console.log(text.innerText);
            //         box.innerHTML = text.value;
            //         // text.style.width
            //         // console.log(text.style.width);
            //         // console.log(text.style.height);
            //         box.style.display = 'block';
            //         box.style.width = text.style.width;
            //         box.style.height = text.style.height;
            //     }

        // })
    </script>
</body>

</html>